APPLICATION FOR REISSUE OF 



Dan S. Bloomberg et al 



U.S. Patent No. 6,076,738 



SELF-CLOCKING GLYPH SHAPE CODES 



Express Mail EEM14726US 



M PATENT 
Attorney Docket No. D/89194R 



1 

SELF-CLOCKING GLYPH SHAPE CODES 

This is a continuation of application Sen No. 07/931,554, 
filed Aug. 18, 1992 AB which, in turn, was a continuation of 
application Ser. No. 07/560,514, filed Jul. 31, 1990 AB. 5 

FIELD OF THE INVENTION 

This invention relates to self -clocking codes for recording 
digital data on hardcopy recording media and, more ]Q 
particularly, to codes composed of glyphs that have digital 
data value's encoded in their shapes. Advantageously, the 
glyphs are selected so that they tend not to degrade into each 
other, but the broader aspects of this invention are directed 
toward codes composed of discriminate glyphs, without 15 
specific limitation to the amount of image degradation 
and/or distortion the codes can tolerate. 

Even more specifically, this invention relates to codes of 
the foregoing type that have a generally uniform textured 
appearance when they are printed or otherwise rendered in 2 o 
hardcopy form. The texture of higher spatial density codes 
is difficult for the casual observer to discern, so those codes 
commonly are described as having a generally uniform gray 
appearance. 

CROSS REFERENCE TO RELATED ^ 
APPLICATIONS 

Binary image processing and convolution filtering tech- 
niques for decoding self-clocking glyph shape codes are 
described herein, but those decoding processes are covered 30 
by concurrently filed and commonly assigned U.S. patent 
applications of Dan S. Bloomberg and Richard G. Stearns et 
al. Specifically, the Bloomberg application is on "Binary 
Image Processing for Decoding Self-Clocking Glyph Shape 
Codes," and the Stearns et al. application is on "Convolution 35 
Filtering for Decoding Self-Clocking Glyph Shape Codes." 
Furthermore, the adaptive scaling that may be utilized for 
scaling either or both of the above decoding processes to the 
decoding of a self -clocking glyph shape code of unknown 
spatial periodicity is covered by a concurrently filed and 40 
commonly assigned U.S. patent application of Bloomberg et 
al. on "Adaptive Scaling for Decoding Spatially Periodic 
Self-Clocking Glyph Shape Codes." 

BACKGROUND OF THE INVENTION 45 

Plain paper still is a favored recording medium for storing 
and transferring human readable information, but the emer- 
gence of electronic document processing systems has made 
it evident that the functional utility of plain paper and other 50 
types of hardcopy documents could be enhanced signifi- 
cantly if the human readable information they normally 
convey was supplemented by writing appropriate machine 
readable digital data on them. This machine readable data 
would enable the hardcopy document to actively interact 55 
with such a document processing system in a variety of 
different ways when the document is scanned into the system 
by an ordinary input scanner. See, for example, the copend- 
ing and commonly assigned U.S. patent applications of 
Frank Zdybel, Jr. et al. and Walter A. L. Johnson et al., which 60 
were filed May 30, 1990 on "Hardcopy Lossless Data 
Storage and Communications for Electronic Document Pro- 
cessing Systems" (D/89190) and on "Form and System 
Utilizing Encoded Indications for Form Field Processing" 
(D/90003), respectively. 65 

As a general rule, digital data is recorded by writing two 
dimensional marks on a recording medium in accordance 
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with a pattern which encodes the data either by the presence 
or absence of marks at a sequence of spatial locations or by 
the presence or absence of mark related transitions at such 
locations. Ordinary magnetic and optical digital data record- 
ing conform to this style of encoding. Furthermore, the 
bar-like codes which have been proposed previously for 
recording digital data on paper also conform to the above- 
described encoding style. See U.S. Pat. No. 4,692,603 on 
"Optical Reader for Printed Bit-Encoded Data and Method 
of Reading Same," U.S. Pat. No. 4,728,783 and U.S. Pat. 
No. 4,754,127 on "Method and Apparatus for Transforming 
Digitally Encoded Data into Printed Data Strips," and U.S. 
Pat. No. 4,782,221 on "Printed Data Strip Including Bit- 
Encoded Information and Scanner Contrast. 

Considering the aforementioned bar-like codes in some 
additional detail, it will be seen that their visual appearance 
is highly variable because it is data dependent, so they tend 
to have a motded appearance. This mottling is a readily 
discernible departure from the clean, crisp appearance of 
high quality printed documents, so it may be aesthetically 
objectionable to some observers. Furthermore, another 
drawback of these bar-like codes is the overhead that they 
contemplate. In particular, as taught by the above-identified 
patents, this overhead includes the registration marks which 
are provided for preserving the data clock, as well as the 
header information which is provided for describing the 
organization of the encoded data, such as the number of bits 
encoded along a given line of code. 

It, therefore, will be evident that there is an urgent need 
for relatively efficient, visually improved codes for record- 
ing digital data on plain paper and other types of hardcopy 
recording media, especially for applications in which such 
machine readable data is to be recorded in visual juxtapo- 
sition with human readable information. Furthermore, it will 
be appreciated that there is a need for efficient and reliable 
techniques for recovering digital data from such codes. 
Moreover, inasmuch as images carried by hardcopy docu- 
ments often are replicated, such as by photocopying and by 
facsimile reproduction, it will be apparent that it would be 
very beneficial to have data encoding and decoding tech- 
niques that can tolerate a significant amount of image 
distortion. 

SUMMARY OF THE INVENTION 

In response to the foregoing and other needs, the present 
invention provides self-clocking glyph shape codes for 
encoding digital data in the shapes of glyphs that are suitable 
for printing on hardcopy recording media. Advantageously, 
the glyphs are selected so that they tend not to degrade into 
each other when they are degraded and/or distorted as a 
result, for example, of being photocopied, transmitted via 
facsimile, and/or scanned-in to an electronic document pro- 
cessing system. Moreover, for at least some applications, the 
glyphs desirably are composed of printed pixel patterns 
containing nearly the same number of ON pixels and nearly 
the same number of OFF pixels, such that the code that is 
rendered by printing such glyphs on substantially uniformly 
spaced centers appears to have a generally uniform texture. 
In the case of codes printed at higher spatial densities, this 
texture is likely to be perceived as a generally uniform gray 
tone. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Still other features and advantages of this invention will 
become apparent when the following detailed description is 
read in conjunction with the attached drawings, in which: 
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FIG. 1 is a simplified block diagram of an electronic 
document processing system for carrying out and taking 
advantage of the various aspects of the present invention; 

FIG. 2 is a functional block diagram of a typical 
processor/printer interface for the document processing sys- 
tem shown in FIG. 1; 

FIG. 3 is a coding diagram for illustrating the bit encoding 
that is provided by a relatively simple self-clocking binary 
glyph shape code composed of rotationally variant glyph 
shapes; 

FIG. 3 A is another coding diagram for illustrating the bit 
encoding of binary data in a rotationally invariant glyph 
shape code; 

FIG. 3B depicts typical data cell structures, as well as 
typical printed pixel patterns for rotationally variant glyph 
shapes of the type shown in FIG. 3; 

FIG. 4 is high level functional flow diagram of a first 
glyph code decoding process; 

FIG. 5 is a more detailed flow diagram of the glyph center 
locate, label and sort phase of an implementation of decod- 
ing process shown in FIG. 4; 

FIG. 6 is a bitmap image of labelled glyph center loca- 
tions that are candidates for recalibration by the optional 
calibration process shown in FIG. 5; 

FIG. 7 is a relatively detailed flow diagram of the glyph 
read/error detect phase of the aforementioned implementa- 
tion of the decoding process shown in FIG. 4; 

FIGS. 8 and 9 illustrate pixel search regions that are suited 
for use in decoding relatively low and relatively high density 
glyph codes, respectively; 

FIG. 10 is a high level functional block diagram of system 
wherein glyph shape encoding and decoding is used for data 
containing error correction codes (ECC); 

FIG. 11 is a functional block diagram of a morphological 
filtering process for filtering a scanned-in bitmap image of a 
glyph code to isolate the ON pixels at or near the centers of 
the glyphs through the use of large filters which are config- 
ured in accordance with the periodicity of the glyph code 
image; 

FIG. 12 is a bitmap image of a typical glyph code; 

FIG. 13 is a bitmap image illustrating the effect of 
applying the filtering process shown in FIG. 11 to the bitmap 
image shown in FIG. 12; 

FIG. 14 is another bitmap image to illustrate the effect of 
iteratively reapplying the second level filtering of the filter- 
ing process of FIG. 11 to the bitmap image shown in FIG. 
13; 

FIG. 15 is a functional block diagram of an iterative 
second level filtering process; 

FIG. 16 is a bitmap image of a glyph code filtered by an 
alternative morphological filtering process for spatially 
separating the glyph centers; 

FIG. 17 illustrates a bounding box expansion of the pixel 
patterns within the bitmap image shown in FIG. 16; 

FIG. 18 is a bitmap image showing the isolation of the 
glyph center pixels that can be achieved, in the case of 
relatively low spatial density glyph codes, by identifying the 
centers of gravity of the individual glyph related pixel 
patterns within the bitmap image shown in FIG. 16 or by 
performing a thinning process on those patterns or on their 
bounding box expansions as shown in FIG. 17; 

FIG. 19 is a functional block diagram of a preliminary 
morphological filtering process that utilizes large filters for 
increasing the spatial separation of the glyphs of higher 
spatial density glyph codes; 
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FIG. 20 is a functional block diagram of a morphological 
bitmap image repair process that may be employed for 
restoring ON pixels to glyph center locations when the 
filtering process of FIG. 19 creates holes in the bitmap at 
5 those locations; 

FIG. 21 is a bitmap image of the glyph centers of a 
relatively high density glyph code, such as may be produced 
by performing a thinning process on the bitmap shown in 
FIG. 17 or on a bitmap produced by the image repair process 
10 of FIG. 20; 

FIG. 22 is a functional block diagram of an iterative 
morphological thinning process that may be employed for 
producing the bitmap image shown in FIG. 21; 

FIG. 23 is a functional block diagram of a morphological 
15 process for isolating glyph center pixels through the use of 
small, weakly matched hit- miss filters; 

FIG. 24 is a functional flow diagram of a decoding 
process which utilizes convolution filtering of the bitmap 

20 ^yP 0 ima S e for l° catin g me cento™ of inc &YV hs ^ the 
bitmap image space and for classifying the glyphs in accor- 
dance with their shapes; 

FIGS. 25A and 25B illustrate the results of convolving 
unweighted and weighted filters, respectively with a glyph 
25 shape that is strongly matched by the filters; and 

FIG. 26 is a fragmentary flow diagram for illustrating a 
modified embodiment of the decoding process shown in 
FIG. 24. 

30 DETAILED DESCRIPTION OF THE 

ILLUSTRATED EMBODIMENTS 

While the invention is described in some detail herein- 
below with specific reference to certain embodiments, it is 
to be understood that there is no intent to limit it to those 
35 embodiments. On the contrary, the aim is to cover all 
alternatives, modifications, and equivalents falling within 
the spirit and scope of the invention as defined by the 
appended claims. 

40 A. An Examplary Environment 

Turning now to the drawings, and at this point especially 
to FIG. 1, there is an electronic document processing system 
21 to illustrate a typical environment for this invention. In 
45 keeping with standard practices, the document processing 
system 21 comprises a digital processor 22 having a main 
memory 23 and a mass memory 24, an input scanner 25 for 
scanning digital representations of selected hardcopy docu- 
ments into the processor 22, and a printer 26 for printing 
50 hardcopy renderings of selected ones of the files that are 
listed on the file directory (not shown) of the processor 22. 
Furthermore, there is a user interface 27 for enabling a user 
to interact with the processor 22, the input scanner 25, and 
the printer 26. 

55 As will be understood, the user interface 27 collectively 
represents the input devices through which the user enters 
control instructions for the input scanner 25 and for the 
printer 26, as well as the image editing and manipulation 
instructions for the processor 22. Additionally, the interface 
60 27 represents the output devices through which the user 
receives feedback with respect to the actions that are taken 
in response to the instructions that are entered by the user or 
otherwise, such as under program control. For example, the 
user interface 27 generally includes a keyboard or the like 
65 for entering user instructions, a monitor for giving the user 
a view of the process that is being performed by the 
processor 22, and a cursor controller for enabling the user to 
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J; c pnr de^riotions But, for otbet applications, it may be 

mo ve a cursor for making selection, from and/or or enter- PDL tocnP^ bk [ Q have the glyph encoder 33 insert 
ingdataintoaprocessthatisbeingd.splayedbythemonttor «ry ^ ^ formatted b.tmapped 

(none of these conventional components is shown). ^ ae e file lh at is provided for the printer 26. PDL descrip- 

The illustrated document processing system 21 is ; ^ f , h shape encod ed data may take several different 

cen\raliz d so it bas been simplified by assuming that all * f >J u F din encaps ulated bUmap represe ntattons of the 

co£ insect ons and all image editing and manipulate code | n which such data is encoded font descnptions and 

insect o^slre executed by the processor 22 under program , t locations for bitmap representations of the .nmvidual 

I^o ale however, the execution of these instruc- J coded x h shipe s (assuming that such bitmaps exist on 

^mav bThaSled by several different processors, some 6 or ^ ^loadable to the font directory of the printer 26) 

or S of iSLh may have their own main memory and even « ^ ^ ^ descriptioDS o£ the bitmaps for the encoded 

iheir own mass memory. Likewise, either or both of the input glvpQ shapes. 

ctnrT^Tnd the Jrinter 26 may have its own user ™ icularlyj m accord ance with the present inv en- 

S as indicated by the dashed lines 28 and 29 as shown ^ nog. 2 aDd 3, the digital data 35 to is 

TesSctively Indeed, it will be evident that the document ^ encoder 33 * eQCO ded in the shapes o toe 

oTo«S system 21 could be reconfigured to have a « J* 36 which the encoder 33 causes the printer 26 to , print 

dSd architecture .0 operate with a remote input sea*- ^ ^ ^.^ ^ setting 

neY and/or a remote printer (not shown). Data could be de becauS6 the ^ tha t is printed on the recording 

n Jfored from and to such remote scanner and pooler has a separate glyph 36 for each of the enco^d data 
TermSrvia dedicated communication links or switched values. In practice, as shown in FIG. 3B, each of the P"°J^ 

communication networks (also no. shown). 20 ^ 36 is denned by the pixel pattern that is pnnud 

scanned-in image into single bit digital values (1* 1 or ■ ^ dimensional ««y of lopca bl P ^ 

"fv'1 it will be understood that it could be a gray-scale ined S12ei such as a 10 ceuxio tcu iu 6 .•=•„.„,, 

i'ne fo? SnvertLg the pixels into multi-bit values. 35 G1 h ^ enC oding clearly permits of many different 

FuXrmSe TSb? evident that the scanner 25 could .^jZnJU some of which are smtable for the encod 

mHS^a such PDL A.%^-Wrf-^^-*S 

S, u ° ^ ^Mhemllves butTvTbe assumed for purposes 55 S Sake the form of a gray scale appearance when 
TiZ&ZgSZE mat the printer 26 is a bitmap Ugh density ff hs are J^^^Jfc 
printer that receives PDL files from the processor 22. J™j£^jH ZtZZSZJ* ^ contour 

B. Glyph Shape Encoding M ( colk ctively referred to berem as ^^j^^S'g 

To carry out this invention, there is a glyph encoder 33 for ^^J^^^J^^^&lia^f different 

causing^ printer 26 to print machine readable dtgital data rota^na Uy invanan Qf ^ pixek , tb 

glyphs on the recording medium, eUher alone or m juxta- conteuR, but ^ respec ,ively. See FIG 3A 

po'sLn with human readable info~ °co* ngotu, ^ ^ rf ^ 

cations the glyph encoder 33 may be cheated ^th the ss forjn « P^ ^ ^ ^ aestheticall pleasmg g, ay 

=^en°fi^^ fo-byincreas^ordecreasmg.eONp.e.contentofthe 
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liyph code could be modulated (by means not shown) m £pta ^«mockg W ^ ^ ^ 
accordance with, say, gray scale pictorial values, thereby ^ in accordance with the spatial 
imputing a gray scale pictorial quality to the pruned code. ggta W^a«^ ^ ^ ^ ^ 
While glyph shape encoding can be extended m theory to ^ ^ addressing the glyphs in the same order as 
the encoding of digital values of any given bit length, n ^ ^ ^ ^ ±Qm Q ^ if desiredj a pomter (not 
simplv by utilizing a code having 2 permissible glyph be ided for randomly accessing the glyphs 
shapes, the code should be selected with care to ensure that ^ ^ ^ preselected locations within the bitmap image 
its glyph shapes can be discriminated from each other ^ ^ ^ ^ C0QStrucled at 45 for decoding 
reliablv because such discrimination is essential tor accu- 0Qes of lhe glyphs i n the order in which they are 
rately recovering the data that is encoded therein. accessed For example, a straightforward X-Y seek may be 
^ a- f n vnh Shane Codes employed for relatively rapidly shifting such a pointer from 
C. Decoding of Glyph Shape Lodes the center of any one glyph to the center of any other glyph 
1 Overview 15 in the bitmap image space by computing the direction and 
LU J , u the number of glyph centers in and by which, respectively 
Turning now to FIG. 4, printed glyph codes of the the X and the Y coordinates of any two given glyph centers 
foregoing type are susceptible to being decoded by process- ^ dis laced from eac h other in the bitmap image space, 
ing bitmap images of them. As will be seen that the image Given that directiona i information and those intermediate 
processing techniques that are provided for decoding such ^ ceQter m appropriate seek may be executed by 
glyph codes can tolerate a significant amount of image iQcreme ntally shifting the pointer from glyph center- 
distortion and degradation, so codes earned by scanned-in l0 _ glypn ceQ ter in the indicated direction along, say, the 
photocopies and facsimile copies can be decoded, provided x _*^ ^ ^ pointer has sldpped across the given num- 
ihat the scanned-in document is not too many generations ^ q£ intennediate glyph centers, and by then repeating the 
removed from the original. Of course, printed glyph codes ^ pfocess tQ mcremen tally shift the pointer to its 
can be regenerated by employing a suitable electronic docu- ^nded destination along the other or Y-axis, 
ment processing system for decoding the code » recover the ^ the cncoded data va lues from the glyph 
encoded data and by then reprinting the code with that very ^ ^ image of the code (where n ^ 
same data encoded therein, with both the decoding and . v ^ ^ ^ v ^ cncoded in cach of me glyph 
re-encoding being performed essentially as described herein. ^ J> ^ ^ ^ ^ by a mief ^ ^ matched 
In certain decoders, the image processing which is per- ^ & fCS dve one of the 2" permissible glyph shapes. For 
formed for decoding the glyph codes first locates the glyphs c k each 0 f these images can be morphological y 
in the X-Y coordinates of the bitmap image space, then ssed - m accordance with a hit-miss filter that is weakly 
constructs a table for indexing the glyphs in the spatial order ^ atched to a respective one (and only one) of the permis- 
in which data was encoded in them, and then analyzes the 35 ^ . shapes ^ yi elds T differently filtered ver- 
glyphs in indexed order for sequentially extracting the data ^ q£ ^ bilmap Specifically, as a result of the 
values that are encoded in them. In other decoders, the image ^ ^ fiUcrin& the pixel paUem prox imate to any given 
processing classifies the glyphs by their shapes while con- 0f « data ubcl » location in any given one of the 
currently locating their centers in the bitmap image space, so m ^ images fc depeDdent upon the precision of the match 
the decoded values of the glyphs conveniently are indexed ^ betweeQ the hit.miss filter used to prepare the given image 
to the bitmap image space. However, these spatially indexed ^ ^ glyph at the gi vcn da ta label locauon (i.e., 
decoded data values may be sorted in accordance with the ^ ^ matchj lhe me number of <W pixels 
spatial template or pattern that governs their spatial ordering oximate me e data label location). Therefore, the pixel 
if it is desired to restore their serial order in the time domain. Uems of me filtered images are compared, as at 52, data 

ur «inc 45 label location-by-data label location in logical encoding 

2. Decoding By Binary Image Processing ^ ^ dQm acces& order)> to dete rmine and sequen- 

a Introduction tially read out, as at 53, the data values encoded in succes- 

In the decoding process illustrated by FIG. 4, the bitmap s ive ones of the glyphs, 

image of the glyph code is first processed morphologically b Definitions 

and/or through the use of a pixel search technique to isolate 50 ^ tQ consideriDg me decoding process in further detail, 

the approximate or apparent centers of the glyphs, as at 41. [{ be helpful t0 brie fly define some of the terms that 

Predetermined ones of these apparent glyph centers, such as ^ ^ adopted for desC ribing "morphological image 

the apparent centers of the corner glyphs, then are employed processing operations": 

as reference points for computing at 42 appropriate skew « Morph ological operation" is an operation on a bitmap 

and X and Y scaling correction factors to compensate for the 55 ^ image „ ) that ^ a local mlc at 

skew errors and the X and Y scaling errors, respectively, * v ^ ^ source ^ t0 creale anot her 

which may have been introduced into the glyph code while ^ r ^ ^ the « destinat ion image). For 

it was being copied and/or scanned-in. As will be seen, these conveaience me ^urce and destination images sometimes 

compensating factors are employed for computing vectors tc{cm & to as "pixelmap" images so that the operational 

that enable a glyph center labelling process to jump from 60 ^ ^ ^ Qperaling on each "pixel". "Bitmap" 

glyph center-to-glyph center (or, more precisely, to a ikely 'Wlmap" are synonymous terms for a data structure of 

location of the next glyph center)^Thus, a relative y local- ^ p ^ ^ aod « pixer arc ^ d iDterc hange- 

ized pixel search process is sufficient for labelling the abl herein t0 descriD e the contents of such a data structure, 

apparent center pixel of each glyph with its X-Y image : space "Structuring Element (SE) is an image object, typically of 

coordinates, as at 43. Spurious image n 0l se effectively is 65 size a ^ d ^ ple shape , for probing the 

rejected at this point because no labels are provided for the cxtract Common from it through the use 
noise components of the image. 
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of a selected morphological operations. The SE's referred to 
herein below are binary SE's. They are illustrated by using 
solid circles to identify their "ON" pixels and hollow circles 
to identify their "OFF" pixels. Their centers are identified by 
a video cross. SE's also may include "Don't Care" pixels, so 5 
it is noted that such pixels are represented by empty squares 
The following terms are specific to binary morphological 
operations: 

"EROSION" is an operation that is performed by probing 
a binary source image with a SE to write an "on" (1) or an 10 
"off' (0) pixel into the destination image for each pixel 
location within the source image, with the logic level of the 
pixel that is written at any given location depending upon 
whether the SE is matched or not by the source image when 
it is centered on the given pixel location. When the SE to be 15 
matched contains both "hits" and "misses," the matching 
operation commonly is called a "hit-miss transform." 
However, to simplify this disclosure, the definition of ERO- 
SION has been expanded to include such hit-miss trans- 
forms. 20 

"DILATION" is an operation that is performed by probing 
a binary source image with a SE to write the SE into the 
destination image on centers corresponding to the locations 
of all "ON" pixels in the source image. As used herein, the 
DILATION is defined only for "hits" in the SE, so "misses" 25 
are ignored. Thus, the dilated destination image is the union 
of all replicas of the SE translated to all 1-pixels of the 
source image. 

"OPENING" is an operation for replicating a SE in the ^ 
destination image for each match to the SE in the source 
image. It is equivalent to an EROSION of a source image by 
an SE followed by a DILATION of the eroded image by the 
same SE. In keeping with the foregoing definitions of 
EROSION and DILATION, the definition of the OPENING 35 
operation has been expanded to include an EROSION with 
an SE containing both "hits" and "misses" followed by a 
DILATION with only the "hits" in the SE. 

"CLOSING" is an operation composed of a DILATION 
of a source image followed by an EROSION of the dilated w 
image. A CLOSING of an image is equivalent to a bit 
inversion of an OPENING that is performed on a bit inverted 
source image. In view of the foregoing definition of 
DILATION, it will be understood that a CLOSING is 
defined herein only for "hits" in the SE, so any "misses" are 45 
ignored. 

Morphological operations are translationally invariant. In 
other words, a source image may be translated prior to be 
transformed, thereby causing the result to be translated or 
shifted by the same amount, without otherwise changing it. 50 
This means that these operations may be implemented with 
a high degree of parallelism because each bit or pixel in the 
source image is processed in accordance with the same rule. 

EROSION, DILATION, OPENING and CLOSING 
operations performed with SE's consisting only of "hits" are 55 
geometrically "increasing" operations. Therefore, if a first 
image is contained in a second image, any of these opera- 
tions that are performed with such a SE on the first image 
will also be contained in the second image. Furthermore, 
CLOSING is "extensive", and OPENING is "antiexten- 60 
sive". Accordingly, the source image is contained in the 
destination image when the source is transformed by a 
CLOSING, and the destination image is contained in the 
source image when the source is transformed by an OPEN- 
ING. The results of OPENING and CLOSING operations 65 
are independent of the position of the center of the SE. 
Moreover, OPENING and CLOSING operations are 
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indempotent, which means they will not change the trans- 
formed image if they are reapplied to it. 

Other terms that are sometimes used in describing mor- 
phological operations are: 

a "4-connected region" is a set of ON ("l")pixels, such 
that a path between any two of those pixels can be found that 
stays entirely within the set of ON pixels and consists of 
only horizontal or vertical 1 -pixel moves. 

a "8-connected region" is a set of ON ("l")pixels, such 
that a path between any two of those pixels can be found that 
stays entirely within the set of ON pixels and consists of 
only horizontal, vertical or diagonal 1 -pixel moves. 

A "hit-miss" SE is an SE that specifies a non-zero set of 
ON pixels and a non-zero set of OFF ("0") pixels, with those 
two sets being non-overlapping (i. e., non -intersecting). A 
"weakly" matched filter specifies relatively few pixels of the 
pixel pattern to which it is matched, while a "strongly" 
matched filter specifies a large percentage of the pixel 
pattern to which it is matched. 

A "hit-only" SE is an SE that specifies a non-zero set of 
ON pixels. 

c. A Detailed Implementation 

Referring now to FIG. 5, in keeping with generally 
accepted practices, the processor and main memory 
resources which are utilized to execute the glyph decoding 
program are re-initialized, as at 61, each time the decoding 
program is invoked. In the embodiment illustrated in FIG. 1, 
the processor 22 communicates with its main memory 23 
and, if necessary, its mass memory 24 (FIG. 1) to carry out 
the glyph decoding process, but it will be evident that the 
decoding process could be performed under the control of a 
separate programmed processor (not shown) through the use 
of the main memory 23 or through the use of a separate 
memory system (not shown). 

i. Clock Recovery 

Once the system has been initialized to decode a given 
glyph code, a copy of the bitmap image of the code is loaded 
into main memory, as at 62, and this image then is 
transformed, as at 63, to provide an identically scaled bitmap 
image composed of at least one centrally located bit or 
"pixel," but no more than a few, for each of the glyphs of the 
code. As described hereinbelow, the process for performing 
the transformation 63 typically is tailored to the spatial 
density at which the glyphs are printed because high density 
glyphs are more likely to be inseparably merged by the 
blurring that occurs during printing, copying and scanning 
than lower density glyphs. If the scanned-in glyphs are well 
separated, they may be shrunk to a single pixel near their 
respective centers. If, on the other hand, the scanned-in 
glyphs are touching, they may first be isolated from each 
other by filtering and then shrunk. For the moment it will be 
assumed that the transformation 63 transforms the scanned- 
in bitmap of the glyph code to a bitmap containing a single 
pixel at the approximate center of each data cell of the code, 
but it is to be understood that this is not essential. 

ii. Determining Skew and Scale 

In practice, the scanned-in image of the glyph code which 
is to be decoded may be skewed from the horizontal in a 
clockwise or counterclockwise direction, and may be dis- 
torted by scaling errors of different magnitude along its 
X-axis and/or its Y-axis. For that reason, provision is made 
at 65 for computing skew and scale correction factors to 
correct for such errors on a glyph-by-glyph basis (as shown) 
or on a data block-by-data block basis not shown or through 
the use of an image deskewing and rescaling process (also 
not shown). 
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jumps to the likely center location of the oext neighboring 
glyph. Conversely, if the search fails to find a nearby ON 
pixel, the process suitably returns to the location at which it 
expected to find the center pixel for the glyph to label that 
location with its X-Y coordinates before jumping ahead to 
locate the center pixel of the next glyph. This process 
continues glyph-by-glyph and row-by-row of the scanned-in 
glyph code to provide a X-Y coordinate label in the bitmap 
image space for each and every glyph center location. 

iv. Recalibrated Glyph Center Labeling (Optional) 

As shown in FIG. 6, the glyph center labeling that is 
performed by the above-described jump and search process 
may contain errors if the glyph centers are not well separated 
in the glyph center bitmap image. Some of the transforma- 
tion processes that may be employed for producing a glyph 
center bitmap image from a scanned-in bitmap image of a 
high density glyph code do not guarantee that such a 
separation will exist for all glyph centers, so there is an 
optional calibration process for recomputing the X-Y coor- 
dinate labels for the glyph centers of such images. 

Returning to FIG. 5, it will be seen that this optional 
calibration process uses the X-Y coordinates for the center 
of gravity of one or more sets of glyph center pixels for 
recomputing the X-Y coordinates for all of the glyph center 
pixels within each of those sets based on the average 
distance of those pixels from the center of gravity of the 
given set. This calibration may be performed once to cali- 
brate the X-Y coordinates of the glyph center pixels relative 
to the center of gravity of the glyph center bitmap image. Or, 
as shown, it may be repeated, as at 81, for calibrating the 
X-Y coordinates of successive sets (e.g., 16x16 blocks) of 
glyph center pixels, as at 82, with respect to their respective 
centers of gravity, as determined at 83. 

v. Restoring Encoded Data Values to the Time Domain 
After the X-Y coordinate labels have been applied to the 

glyph center pixels and all necessary calibrations of them 
have been completed, the X-Y coordinate labels ordinarily 
are sorted into a logical block sequence, thereby serially 
re-ordering them in accordance with the order in which data 
is encoded into the glyphs labeled by them. Moreover, as 
indicated at 85, incrementally increasing index values are 
assigned to the re -ordered labels so that they can be retrieved 
easily in sorted sequence. 

vi. Deterrnining Data Values from Glyph Shapes 
Turning to FIG. 7, given the indexed X-Y coordinate 

labels for the glyphs, the glyph code can be decoded by 
analyzing the shapes of the individual glyphs in logical 
sequence to serially determine the data values that have been 
encoded in them. To perform this glyph shape analysis, the 
scanned-in bitmap image of the glyph code, as at 101, is 
separately filtered at 102 in accordance with a plurality of 
different filters, as at 103, each of which is selected to pass 
pixels from a respective one of the permissible glyph shapes 
and to suppress pixels from all of the other glyph shapes. For 
that reason, the filters may be described as being individu- 
ally "tuned" to respective ones of the permissible glyph 
shapes. The bitmap filtering may be performed in series as 
shown in FIG. 7 or in parallel as indicated in FIG. 4. In any 
event, the filtered bitmaps are stored at 104, so that they can 
be retrieved during the glyph-by-glyph analysis phase of the 
decoding process as described below. 

To provide the filtered bitmap images, the bitmap image 
of the glyph code advantageously is morphologically 
ERODED, through the use of independent operations, in 
accordance with a plurality of different weak hit-miss filters, 
each of which is relatively well matched to a different one 
of the permissible glyph shapes and relatively poorly 
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matched to all of the others. These filters are referred to as 
"weak" hit-miss filters because they only loosely specify the 
shapes of the glyphs (i.e., the patterns of "ON" and "OFF" 
pixels that define the glyph shapes). Consequently, the 

5 filtering of a matching glyph within the source image 
typically causes several ON pixels to be written into the 
target or filtered image near the center of the matching 
glyph, while the filtering of a non-matching glyph results in 
significantly fewer, if any, ON pixels being written into the 

10 targeted image near the center of the non-matching glyph In 
other words, the filtering causes a significantly larger num- 
ber of ON pixels to be written into a filtered image for the 
glyphs that are well matched by the filter that is used to 
produce that particular image than for the glyphs that are 

15 unmatched or only poorly matched by that filter. 

After it is determined at 105 that all of the filtered bitmap 
images have been constructed, a glyph index pointer 107 is 
set, as at 106, to the index value for the first glyph that is to 
be decoded, thereby retrieving the X-Y image space coor- 

20 dinate label for the first glyph from memory. This label is 
used at 111 for spatially addressing one after another of the 
filtered bitmap images at approximately the center of the 
glyph that is to be decoded, so that the ON pixels that each 
of those images contains proximate the center of that par- 

25 ticular glyph can be counted as at 112. These counts, in turn, 
are stored in separate cells of a data array, as at 113, 

Typically, the pixel counting is performed by starting at 
the labeled center point of the addressed glyph and by then 
moving outwardly from there to count the number of ON 

30 pixels falling within a selected number of progressively 
larger squares centered on the glyph center point. This 
"square ring" search pattern expands in all directions at a 
rate of one pixel position/ring, but the search is confined to 
the data cell for the glyph that is being decoded. For 

35 example, as shown in FIG. 8 a three ring search is appro- 
priate for glyph codes written at a density of 900 bits/in 2 
using 10 pelxlO pel data cells for the glyphs. In contrast, as 
shown in FIG. 9, a two ring search is preferred for glyph 
codes written at a density of 3600 bits/in 2 using 5 pelx5 pel 

40 data cells. In both cases, the innermost ring is the X-Y 
labeled center point of the glyph. 

Upon confirming at 115 (FIG. 7) that all of the pixel 
counts for the given glyph have been accumulated, the data 
array containing them is sorted at 116 in rank order by count 

45 value, so that the two largest counts can be extracted from 
it straightforwardly for comparison, as at 117. If these counts 
are unequal, as determined at 121, the data value associated 
with the glyph shape yielding the largest count is assigned 
to the index for the given glyph, as at 121. If, on the other 

so hand, the equality test 121 determines that the two largest 
counts are equal, an error count is incremented to track the 
number of decoding ambiguities that occur and the X-Y 
coordinate label of the ambiguous glyph is stored to indicate 
where the ambiguity or "error" occurred. Thereafter, an 

55 estimate of the data value that was encoded in the ambiguous 
glyph is assigned to its index, as at 125. Then, if it is 
determined at 126 that there are more glyphs to be decoded, 
the glyph index value is incremented at 107 to repeat the 
count and compare process for the next glyph. 

60 vii. Systems Utilizing Error Correction Encoding 

As shown in FIG. 10, glyph shape encoding and decoding 
may be employed for data containing error correction codes. 
To that end, the data is glyph shape encoded at 131, and the 
encoded glyph shapes then are converted into a raster format 

65 at 132 so that they can be printed at 133 on a suitable 
recording medium, such as plain paper, by a bitmap printer. 
Subsequently, the printed image (which may include human 
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readable information, as well as the glyph code) is converted 
into a bitmap image by an input scanning operation 134. 
This bitmap image is parsed at 135 to isolate the scanned-in 
image of the glyph code, so that the above-described decod- 
ing process can be employed at 136 to assign decoded data 5 
values to the glyph or data indices. The glypb decoded data 
is then processed at 137 by an error correction code decoder 
to provide the original data in error corrected form, 
viii. Transforms for Isolating Glyph Center Pixels 

Returning to the problem of identifying the centers of the 10 
glyphs in a glyph shape code, three different techniques will 
be described for performing that function. Two methods for 
transforming the scanned-in bitmap image of the glyph code 
into a bitmap of the glyph center pixels, as at 63 in FIG. 5, 
will be described in this section, and a third method that does 
not require such a transformation will be described in the 
following section. Therefore, in this section, it will be 
assumed that the transformation process 63 is carried out to 
isolate the glyph centers as a separate and distinct step from 
the evaluation of the glyphs. As will be seen, the transfor- 
mation process 63 may be performed through the use of 
large filters representing the periodicity of the glyph code 
(these filters typically are on the order of 2-6 cycles long) or 
through the use of small filters representing individual glyph 
shapes (these filters usually are somewhat smaller than the 
glyphs) 

Turning first to the large filter implementations of the 
transformation 63, it will be understood that the glyphs of 
lower density glyph codes (i.e., these that are printed with 
densities of up to about 2500 glyphs/in 2 using glyph cells as 
small as 6 pelsx6 pels) usually are reasonably well separated 
in the scanned-in bitmap image of the glyph code. Therefore, 
as shown in FIG. 11, their apparent center pixels generally 
can be identified with sufficient precision by OPENING the 
scanned-in bitmap image 140 (see FIG. 12) in accordance 
with a large horizontal hit-miss filter, as at 141, and a large 
vertical hit-miss filter, as at 142. The results of these 
OPENING operations are bit-ORed at 143 to construct a first 
level filtered bitmap image having relatively little diagonal 
ON pixel structure. Next, the filtered bitmap image is 
OPENED at 144 and 145 in accordance with the horizontal 
and the vertical hit-miss filters, respectively, and the results 
of these operations are bit-ANDed, as at 146, to provide a 
second level filtered bitmap image having even less diagonal 
structure and less vertical and horizontal structure. See FIG. 
13. If it is desired to further reduce the ON pixel structure 
of the second level filtered image (see FIG, 14) one or more 
additional iterations of the second level filtering process may 
be employed as shown in FIG. 15 at 151-156. 

As shown in FIG. 19, for locating the glyph center pixels 
of higher density glyphs (i.e., densities up to 3600 glyphs/in 2 
using glyph cells as small as 5 pelsxS pels), the bitmap 
image of the glyph code suitably is OPENED at 161 and 162 
in accordance with large horizontal and vertical hit-only 
filters, respectively, and the results of those processes are 
then bit-ANDed at 163 to construct a bitmap image com- 
posed of better separated marks. 

The bit-ANDing 163 of the image OPENING operations 
161 and 162 may create some unintended holes at glyph 
center locations in the resulting bitmap image, but these 
holes can be filled. To that end, this particular version of the 
transformation process 63 (FIG. 5) may further include one 
or more iterations of a fill and repair process. To carry out 
this fill and repair process, as shown in FIG. 20, the filtered 
bitmap is first DILATED at 171 and 172 in accordance with 
large horizontal and vertical hit-only filters, respectively, 
and the dilated images then are bit-ANDed at 173 to prevent 
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the bitmap image from expanding. That image, in turn, is 
OPENED at 174 and 175 in accordance with either the large 
hit-only filter or the large hit-miss filter, and the results of the 
OPENING operations 174 and 175 then are bit-ANDed at 
176. 

Upon the completion of the fill and repair process, the 
bitmap image may have several ON pixels proximate at least 
some glyph locations. However, the image can be thinned to 
approximately one pixel per glyph by performing a iterative 
thinning process on it until thinning stops. As shown in FIG. 

22, this thinning process is initiated with a copy of the 
bitmap image that is to be thinned, as at 190, and with the 
first of a set of four hit-miss SE's, 191-194, respectively. 
These hit-miss filters 191-194 specify spatial sequences of 

15 two ON pixels and one OFF pixel at angles of 0°, 90°, 180°, 
and 270°, respectively. During the initial iteration of this 
thinning process, the bitmap first is ERODED, as at 195, in 
accordance with the first SE 191, and the ERODED bitmap 
then is XORed at 196 with the image 190 that is being 
20 thinned, whereby a single ON pixel is thinned or "trimmed" 
from each glyph location that contains a plurality of ON 
pixels at the orientation of the SE 191, with the pixel that is 
trimmed being the one that aligns with the center position of 
the SE 191. Following this initial thinning, an SE index 197 
25 is incremented to repeat the ERODE and XOR steps 195 and 
196 on the thinned image, using one after another of the 
remaining structuring elements 192-194, so that excess ON 
pixels are trimmed in a predetermined side-to-side order 
from all horizontally and/or vertically adjacent sets of ON 
30 pixels. 

After each iteration of the thinning process, as determined 
at 198, the thinned bitmap image is bit-compared at 199 with 
the bitmap image 190. If the images are identical, thinning 
has stopped, so the process is completed. Otherwise, the 
35 thinned image is copied at 190, and the process is then 
repeated in an attempt to further thin the image. 

Even higher density glyph codes having spatial densities 
up to, say, 5625 glyphs/in 2 with glyph cells as, say, small as 
4 pelsx4 pels may be transformed to locate the apparent 
40 centers of their glyphs using essentially the same process as 
described above for the transformation of the medium 
density codes. However, the transformation of those higher 
density codes generally requires several iterations of the fill 
and repair process 171-176 (FIG. 20). 
45 Alternatively, as pointed out above, the transformation 
process 63 (FIG. 5) can be performed through the use of 
small, hit-miss filters that are weakly matched to the per- 
missible glyph shapes. To accomplish that, as shown in FIG. 

23, the bitmap image of the glyph code is ERODED, as at 
50 201 and 202, in accordance with small SE's that are weakly 

matched to respective ones of the permissible glyph shapes, 
and the results of these EROSIONS then are bit-ORed, as at 
203, to construct a filtered bitmap image composed of 
smaller marks or pixel patterns. For example, when rota- 
55 tionally variant glyphs are employed, the bit-ORing 203 of 
the results of the EROSIONS 201 and 202 will produce a 
filtered bitmap composed of smaller, more circular bit or 
pixel patterns See FIG. 16. This filtered bitmap generally 
contains several pixels near the center of each glyph. 
60 Accordingly, a thinning process of the above-described 
type (See FIG. 22) usually is needed for thinning the filtered 
bitmap to approximately one ON pixel per glyph. This 
thinning process may be preceded by a bounding box 
expansion of the pixel patterns at the glyph locations to 
65 enable the thinning to more precisely isolate the centermost 
ON pixel of each glyph. See FIG. 17 for an example of a 
bitmap image produced by such a bounding box expansion. 
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Also see a copending and commonly assigned U.S. patent 
application of Dan Bloomberg, which was filed Jul. 31, 1990 
under Ser. No. 07/560,659 on "Binary Image Processing for 
Decoding Selfclocking Glyph Shape and which hereby is 
incorporated by reference, for a description of a suitable 5 
bounding box expansion process. 

The thinning of the filtered bitmap (FIG. 16) or of its 
bounding box expanded counterpart may stop before all of 
the glyph centers are well defined by a single, isolated ON 
pixel. In the case of higher spatial density codes, this may 10 
cause potentially significant labelling errors to occur during 
the jump, search and label process 71-73 (FIG. 5), but the 
optional calibration process 81-83 (FIG. 5) usually is able to 
recalibrate the glyph center labels with sufficient precision 
for enabling the glyph shape evaluation phase of the decod- 15 
ing process to track from glyph-to-glyph, as at 107 in FIG. 
7, 

3. Decoding By Convolution Filtering 

Turning now to FIG. 24, there is a convolution filtering 2 o 
process for decoding the glyphs of a glyph shape code from 
a bitmap image of the code, as at 211. As will be seen, this 
process can be carried out, without having to shrink the 
glyphs to locate their apparent center pixels in the X-Y 
image. Instead, the bitmap image 211 is separately con- 25 
volved at 212 with n different filters, each of which is 
strongly matched to a corresponding one of the n permis- 
sible glyph shapes. The images produced by these 
convolutions, in turn, are processed glyph -by-glyph, as at 
213-218, for identifying their X_Y coordinate locations in 30 
the bitmap image space while essentially concurrently clas- 
sifying them by their shapes for decoding, as at 221-224. 
Alternatively, the bitmap image could be convolved, data 
cell-by-data cell, with a set of n matched filters. 
Furthermore, it will be understood that multiple convolu- 35 
tions could be performed for each permissible glyph shape 
to furnish an extended set of convolved images for providing 
additional discrimination between the different glyph 
shapes. 

As shown in FIGS. 25A and 25B, the convolution filters 40 
may be unweighted or weighted, as at 228 and 229, respec- 
tively. An unweighted filter is composed of binary positive 
and negative values, while a weighted filter is composed of 
positive and/or negative gray-scale values. If weighted 
filters, such as the filter 229, are used, they advantageously 45 
are weighted to emphasize the more distinctive features of 
the glyph shapes to which they are matched and to 
de-emphasize the more distinctive features of the other 
glyph shapes. 

More particularly, for decoding a glyph code in accor- 50 
dance with the process shown in FIG. 24, three or more 
non-colinear reference points of known nominal spatial 
relationship to one another are located in the glyph code 
bitmap image space, as at 231, for computing bitmap skew 
and X and Y scale correction factors, as at 232. The X and 55 
Y scale correction factors are employed at 233 for calibrat- 
ing the average center-to-center displacement of the glyphs 
along the X-axis and the Y-axis, respectively, of the bitmap 
image space. The displacement values upon which those 
calibrations are performed may be computed either from 60 
prior knowledge of the spatial density (in printer pels) at 
which the glyphs were printed or from the spatial periodicity 
of the bitmap image of the glyph code as determined by a 
frequency transform, such as a fast Fourier transform or a 
fast Walsh transform. The skew correction factor, on the 65 
other hand, is utilized at 213 for setting the angles of the X 
and Y displacement vectors that enable the image processing 
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to jump from one glyph position to the likely position of the 
next glyph in the bitmap image space with sufficient preci- 
sion to enable the center of the next glyph to be located by 
performing a search over a relatively small local area. This 
local search suitably is carried out in accordance with an 
expanding diamond-like or an expanding square ring-type 
search pattern. In short, it will be apparent that there are 
substantial similarities between the preliminary phases of 
this and the above-described decoding processes. However, 
it also will be evident that this process requires substantially 
less preliminary processing of the glyph code bitmap image 
than those binary decoding processes. 
The glyph code is decoded glyph-by-glyph, starting at 

213 approximately at the center of, say, the UL corner glyph 
(suitable processes already have been described for locating 
that center). To perform the decoding, the bitmap image is 
convolved at 212 with each of the n glyph matching filters. 
This produces n gray-scale images, each of which represents 
the convolved response of the glyph code image to a filter 
that is relatively strongly matched to a respective one of the 
n permissible glyph shapes. A local search is conducted at 

214 in each of these convolved images, from the approxi- 
mate or estimated location of the glyph that is being 
decoded, to label the maximum convolution values the 
respective images contain for that particular glyph with their 
X-Y image space coordinates, as at 215. As shown in FIG. 
24, these local maximum convolution values are readout 
from the convolved images at 214 and are indexed by their 
X-Y bitmap image space coordinates at 215, but it will be 
seen that the X-Y coordinates of the local maxima may be 
used in an alternative embodiment for indexing the sums of 
the convolution values from a small area surrounding those 
local maxima. 

The indexed convolution values (i. e., local maxima or 
sums) for the n convolved images are sorted in rank order by 
value at 216, and the two highest values then are compared 
at 217. If the values are unequal, as determined at 221, the 
data value for the glyph that is being processed is decoded 
by reference to the convolution producing the greater value 
and the X-Y label for that convolution value is assigned to 
the decoded data value for indexing it in the bitmap image 
space. See 222. On the other hand, if it is determined at 221 
that the two largest convolution values are equal, the X-Y 
label for a selected one of them is recorded to identify an 
error location and an error count is incremented, as at 223. 
Thereafter, as indicated at 224, an estimated decoded data 
value is provided by reference to the convolution producing 
the selected convolution value, and the X-Y label or index 
for the selected convolution value is assigned to the decoded 
data value for indexing it in the bitmap image space. 

The foregoing process is repeated to decode the next 
glyph if it is determined at 218 that there is another glyph to 
be decoded. Whenever there is another glyph to be decoded, 
the decoding process employs the bitmap image space X-Y 
coordinates (i. e., index location) of a previously decoded 
neighboring glyph for advancing to the next glyph through 
the use of the above<lescribed jump and search routine. 

Referring to FIG. 26, to increase the noise immunity of 
this decoding process, each of the local maximum convo- 
lution values for the glyph that is being decoded may be 
summed at 231 with its near neighboring convolution values 
from a small surrounding area For example, the convolution 
values may be accumulated, image-by-image, from a small 
diamond or square shaped area centered on the local maxi- 
mum for the glyph that is being analyzed in each of the 
convolved images. The X-Y locations of these local 
maxima, as determined at 233, then are employed for 
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